<template>
	<view class="preview">
		<swiper circular>
			<swiper-item v-for="item in 5">
				<image @click="maskChange" src="/common/images/preview1.jpg" mode="aspectFill"></image>
			</swiper-item>
		</swiper>
		
		
		<view class="mask" v-if="isShow">
			<!-- <view class="goBack">
				<uni-icons type="back" size="30"></uni-icons>
			</view> -->
			<view class="count">3&nbsp;/&nbsp;9</view>
			<view class="time">
				<uni-dateformat :date="new Date()" format="hh:mm"></uni-dateformat>
			</view>
			<view class="date">
				<uni-dateformat :date="new Date()" format="M月d日"></uni-dateformat>
			</view>
			<view class="footer">
				<view class="box" @click="clickInfo">
					<uni-icons type="info" size="28"></uni-icons>
					<view class="text">信息</view>
				</view>
				<view class="box" @click="clickScore">
					<uni-icons type="star" size="28"></uni-icons>
					<view class="text">5分</view>
				</view>
				<view class="box">
					<uni-icons type="download" size="23"></uni-icons>
					<view class="text">下载</view>
				</view>
			</view>
		</view>
		
		<uni-popup ref="infoPopup" type="bottom">
			<view class="infoPopup">
				<view class="popHeader">
					<view></view>
					<view class="title">
						壁纸信息
					</view>
					<view class="close" @click="infoPopClose">
						<uni-icons type="closeempty" size="18" color="999"></uni-icons>
					</view>
				</view>
				<scroll-view scroll-y>
					<view class="content">
						<view class="row">
							<view class="label">壁纸ID：</view>
							<text selectable class="value">123123123</text>
						</view>
						<view class="row">
							<view class="label">分类：</view>
							<text selectable class="value class">明星美女</text>
						</view>
						<view class="row">
							<view class="label">发布者：</view>
							<text selectable class="value">王腾</text>
						</view>
						<view class="row">
							<text class="label">评分：</text>
							<view class="value roteBox">
								<uni-rate readonly touchable value="3.5" size="16"/>
								<text class="score">5分</text>
							</view>
						</view>
						<view class="row">
							<text class="label">摘要：</text>
							<view class="value">今年是我不对谁都不爱东部时间擦但端午i我百度埃及杜绝百度世界杯的Dion丢阿斯顿赛u端设备</view>
						</view>
						<view class="row">
							<text class="label">标签：</text>
							<view class="value tabs">
								<view class="tab" v-for="item in 3">标签</view>
							</view>
						</view>
						
						<view class="cocyright">
							声明：本图片来自于用户投稿，非商业使用，用于免费学习交流，如侵犯了您的权益，您可以拷贝壁纸ID举报至于平台，邮箱302653793@qq.com,管理将删除壁纸，维护您的权益。
						</view>
					</view>
				</scroll-view>
			</view>
		</uni-popup>
		
		<uni-popup ref="scorePopup" :is-mask-click="false">
			<view class="scorePopup">
				<view class="popHeader">
					<view></view>
					<view class="title">壁纸评分</view>
					<view class="close" @click="scorePopClose">
						<uni-icons type="closeempty" size="18" color="999"></uni-icons>
					</view>
				</view>
				<view class="content">
					<uni-rate v-model="userScore" allow-half></uni-rate>
					<text class="text">{{userScore}}分</text>
				</view>
				<view class="footer">
					<button @click="submitScore" :disabled="!userScore" type="default" size="mini" plain>确认评分</button>
				</view>
			</view>
		</uni-popup>
	</view>
</template>

<script setup>
import { ref } from 'vue';

	const isShow = ref(true)
	const infoPopup = ref(null)
	const scorePopup = ref(null)
	const userScore = ref(0)
	
	// 遮罩状态
	const maskChange = () => {
		isShow.value = !isShow.value
	}
	// 点击info弹窗
	const clickInfo = () => {
		infoPopup.value.open()
	}
	// 点击关闭info弹窗
	const infoPopClose = () => {
		infoPopup.value.close()
	}
	// 点击评分弹窗
	const clickScore = () => {
		scorePopup.value.open()
	}
	// 点击关闭评分弹窗
	const scorePopClose = () => {
		scorePopup.value.close()
	}
	// 确认评分
	const submitScore = () => {
		console.log("评分了");
	}
</script>

<style lang="scss" scoped>
.preview{
	width: 100%;
	height: 100vh;
	position: relative;
	swiper{
		width: 100%;
		height: 100%;
		z-index: 1;
		image{
			width: 100%;
			height: 100%;
		}
	}
	.mask{
		&>view{
			position: absolute;
			left: 0;
			right: 0;
			margin: auto;
			width: fit-content;
			color: #fff;
		}
		// .goBack{}
		.count{
			top: 10vh;
			background: rgba(0, 0, 0, 0.3);
			border-radius: 40rpx;
			font-size: 28rpx;
			padding: 8rpx 28rpx;
			backdrop-filter: blur(10rpx);
		}
		.time{
			font-size: 140rpx;
			top: calc(10vh + 80rpx);
			font-weight: 100;
			line-height: 1em;  //去掉行高
			text-shadow: 0 4rpx rgba(0, 0, 0, 0.3) 
		}
		.date{
			font-size: 34rpx;
			top: calc(10vh + 230rpx);
			text-shadow: 0 4rpx rgba(0, 0, 0, 0.3)
		}
		.footer{
			background: rgba(255, 255, 255, 0.8);
			bottom: 10vh;
			width: 65vw;
			height: 120rpx;
			border-radius: 120rpx;
			color: #000;
			display: flex;
			justify-content: space-around;
			align-items: center;
			box-shadow: 0 2rpx rgba(0, 0, 0, 0.1);
			backdrop-filter: blur(20rpx);
			.box{
				display: flex;
				flex-direction: column;
				align-items: center;
				justify-content: center;
				padding: 2rpx 12rpx;
				.text{
					font-size: 26rpx;
					color: $text-font-color-2;
				}
			}
		}
	}
	
	.popHeader{
		display: flex;
		justify-content: space-between;
		align-items: center;
		.title{
			color: $text-font-color-2;
			font-size: 26rpx;
		}
		.close{
			padding: 6rpx;
		}
	}
	.infoPopup{
		background: #fff;
		padding: 30rpx;
		border-radius: 30rpx 30rpx 0 0;
		overflow: hidden;
		scroll-view{
			max-height: 60vh;
			.content{
				.row{
					display: flex;
					padding: 16rpx 0;
					font-size: 32rpx;
					line-height: 1.7em;
					.label{
						color: $text-font-color-3;
						width: 140rpx;
						text-align: right;
						font-size: 30rpx;
					}
					.value{
						flex: 1;
						width: 0;
					}
					.roteBox{
						display: flex;
						align-items: center;
						.score{
							font-size: 26rpx;
							color: $text-font-color-2;
							padding-left: 20rpx;
						}
					}
					.tabs{
						display: flex;
						flex-wrap: wrap;
						.tab{
							border: 1px solid $brand-theme-color;
							color: $brand-theme-color;
							font-size: 22rpx;
							padding: 10rpx 30rpx;
							border-radius: 40rpx;
							line-height: 1em;
							margin: 0 10rpx 10rpx 0;
						}
					}
					.class{
						color: $brand-theme-color;
					}
					
				}
				
				.cocyright{
					font-size: 28rpx;
					padding: 20rpx;
					background: #f6f6f6;
					color: #666;
					border-radius: 10rpx;
					margin: 20rpx 0;
					line-height: 1.6em;
					
				}
			}
		}
	}
	
	.scorePopup{
		background: #fff;
		padding: 30rpx;
		width: 70vw;
		border-radius: 30rpx;
		.content{
			padding: 30rpx 0;
			display: flex;
			justify-content: center;
			align-items: center;
			.text{
				color: #ffca3e;
				padding-left: 10rpx;
				width: 80rpx;
				line-height: 1em;
				text-align: right;
			}
		}
		.footer{
			padding: 10rpx 0;
			display: flex;
			justify-content: center;
			align-items: center;
		}
	}
}
</style>
